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15 FIELD OF THE INVENTION 

The invention generally relates to an e-commerce system, and particularly 
to a web site software system that is modular and easily customizable. 



BACKGROUND 

20 Within the past decade, use of the Internet has exploded. Internet users can 

find information, make purchases, and participate in discussion groups all by using 
a browser such as Netscape Communicator or Internet Explorer from their home 
or office computer. To do so, once connected to an Internet service provider (ISP) 
an Internet user simply enters a domain name in the browser and is brought 

25 (through his/her browser) to an appropriate web site. Each web site is composed 
of one or more web pages which convey information to the Internet user. 

While the growth of the Internet has been enormous, growth of the Internet 
in relation to e-commerce has been significant. For instance, in 1999 on-line 
purchases during the holiday season were estimated at $7 billion while in 1 998 such 

30 purchases were only near $2.3 billion. 

Given the recent explosion in e-commerce, more and more businesses are 
seeking to both institute e-commerce web sites as well as upgrade existing sites. To 
assist in this undertaking, a number of companies have developed web site software 
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products to enable a company-user to set up a web site for its e-commerce business. 
Typically, these software products come in two forms: (1) a full-custom program 
or (2) a "shrink-wrapped" program. 

A full-custom program is designed to satisfy the specific needs of a single 
5 particular user. A full-custom program must therefore be written more or less from 
scratch and will typically be rather complicated, expensive, and time-consuming to 
implement, often taking over a year to develop and containing many thousands of 
lines of code. 

The second type of programs mentioned are shrink-wrapped programs. A 
10 shrink-wrapped program is a fully-developed program that is purchased "as-is" 
"off-the-shelf." Such programs may include catalog software that enables the 
purchaser to quickly and easily set up an on-line catalog or product 
display/description. While such shrink-wrapped products are quick and relatively 
inexpensive compared to their full-custom counterparts, they offer little to no 
1 5 flexibility to the user-purchaser. In other words, the user will have little ability to 
change the look and feel of its web site and generally cannot alter the flow or 
organization of how the web site is presented at all. 

Therefore, it is desirable to create a product that allows customization for 
the user, but can do so for less time and less money than typical full-custom 
20 programming. 

SUMMARY 

A system in accordance with the invention creates a modular software 
product generally for e-commerce applications that is modifiable by a company-user 
25 in terms of not only look and feel, but also functionality and flow. Such a system 
includes a set of business modules where each business module performs a specific 
function. Each business module is accompanied by a respective set of templates, 
each of which models a web page. Within each template is embedded one or more 
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commands. To customize its system, the company-user (1) selects which business 
modules it desires, (2) selects which templates it desires to use with each business 
module, and (3) customizes each template in terms of look and feel. By selecting 
the modules, the company user determines the system's overall functionality, and 
5 by selecting the templates, the company user determines the look and feel and flow 
of the system. Once customized, the company-user populates a database for use 
with the system with company-specific data. 

A system in accordance with the invention is also highly modular. Each of 
the business modules functionally operates independently of one another, although 

10 one may receive data derived from another. Further, modules can be added or 
subtracted from the system depending on the company-user' s business. To provide 
such modularity, the system is built on a foundation that houses functionality 
common to the modules. When a module is added to the system, no other modules 
are affected and the foundation is only minimally modified. 

15 A system in accordance with the invention is useful for modeling a sales 

environment. In one embodiment, such a system is designed to assess an end-user' s 
needs, display product information, allow an end-user to design his/her own 
products, allow an end-user's comparison of products, display promotional 
information, display financing information, locate a company partner, process a 

20 transaction, build loyalty through membership and personalization, and provide end- 
user access to company partner web-sites. 

BRIEF DESCRIPTION OF THE DRAWINGS 
The present invention is described with respect to particular exemplary 
25 embodiments thereof and reference is accordingly made to the drawings in which: 
Fig. 1 is a generalized function block diagram of a system in accordance 
with the invention; 
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Fig. 2 is a generalized diagram illustrating general operation of a system in 
accordance with the invention; 

Fig. 3 is a generalized block diagram of a response loop used in an 
embodiment of the invention; 
5 Figs. 4 and 6-8 illustrate example templates used in one embodiment of the 

invention; 

Fig. 5 illustrates an example of the template of Fig. 4 customized; 
Figs. 9 and 10 are generalized diagrams illustrating system scalability; and 
Fig. 1 1 is a block diagram illustrating how a system in accordance with the 
10 invention models a sales environment. 

DETAILED DESCRIPTION 
A system in accordance with the invention provides software for use in an 
e-commerce environment. In particular, a system in accordance with the invention 

1 5 includes a modular software package that can be customized to a large extent by the 
company-user in considerably less time and for less money than a full-custom 
alternative while providing considerably more flexibility than a shrink-wrapped 
alternative. A system in accordance with an embodiment of the invention is 
designed to provide an Internet-based model of a real-world sales environment to 

20 enable end-users to browse and select products from an on-line catalog, select one 
or more dealers, and to send a faxed, e-mailed, or XML formatted request-for- 
quote (RFQ) to the selected dealer to facilitate the end-user's purchase decision. 
In some embodiments, a system in accordance with the invention will further assess 
an end-user's needs, compare one product to another, initiate purchases, provide 

25 promotional information, configure products, and build customer loyalty. 
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Overview 

Fig. 1 shows a general overview of a system 100 in accordance with the 
invention. Such a system includes a user interface 1 02 . User interface 1 02 includes 
browser 106, such as Netscape Communicator or Internet Explorer. Browser 106 
5 is used by an end-user, such as a customer or potential customer of a company-user 
to view the company's web site. 

As used herein, the term "company-user" refers to the entity that is using an 
embodiment of the invention to develop and maintain a web site. The company- 
user will typically employ an "administrator" to perform the development and 

10 maintenance of the web site. Thus, any reference herein to action taken by the 
company-user will be understood to typically be ultimately implemented on the web 
site by the administrator. The term "end-user" refers to a person other than an 
administrator accessing the company-user's web site through a browser. An end- 
user is often a customer, potential customer, or individual acting on behalf of a 

1 5 customer (such as a company-user employee assisting a customer). 

Modules 130 determine the overall functionality of the system. Each 
module contains different functionality and operates independently of one another. 
Because of their relationship to various occurrences in business, modules 130 are 
sometimes referred to herein as "business modules." Modules can be removed or 

20 added to the system with minimal changes to the overall system and allow the 
system functionality to be customized. Each module 130 is associated with a unique 
set of templates 104 used by a company-user (by way of an administrator) of the 
system to customize and tailor the system to its own needs. Templates can be used 
and viewed by a company-user through a browser 106. Further information with 

25 respect to templates will be discussed later. 

As illustrated in Fig. 1, in one embodiment modules 130 are directed to 
creating an e-commerce sales environment. For instance, catalog module 134 
provides the company-user with the ability to display products and/or product 
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information on-line, while locate module 146 finds the end-user's local company 
partner. As used herein, a "company partner" is any dealer, retailer, distributor, or 
other entity that is affiliated with the company-user or otherwise assists the 
company-user in the sale or distribution of its products or services. Details of these 
5 modules 130 will be discussed later. 

Business modules 130 interact with foundation 110. Foundation 110 is 
essentially the infrastructure for the system 100, including the services commonly 
required by the modules 130, such as response loop 1 12, cart 1 14, data services 
118, and rule engine 124, each of which will be later described in more detail. 

10 Although cart 1 14 is included in foundation 1 10, cart 1 14 behaves like a business 
module 130 and is only included in foundation 110 because it is utilized by a number 
of modules 130. In addition to services commonly required by modules 130, 
foundation further includes various low level services 1 20 and management services 
122 for system administration. Overall, foundation 110 creates a flexible 

15 infrastructure for rapid and cost-effective incremental installations of modules, 
which can be added or replaced to respond to a user company's business needs. 
Thus, foundation 110 provides scalability and information sharing among the 
modules. 

Site server 1 60 is based on Microsoft Site Server or Commerce Server, both 
20 products known in the art, or other similar product. Site server 160 maintains a 
Directory Information Tree (DIT) that includes end-user information (including 
name, address, phone, etc.) and other frequently read data. 

In addition to that in Site Server, other data stores are provided. In 
particular, these data stores include SQL database 170, legacy database 172, and 
25 XML information 174. SQL database 170 is a typical database used with the 
system in accordance with the invention. Legacy database 172 would be used, for 
instance, if a company-user prior to acquiring a system in accordance with the 
invention, already had a database system with stored data. The legacy data is 
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converted using data converter 171 into a useable format and accessed through the 
SQL database 170. For instance, in some embodiments, the company-user creates 
a data extract for legacy data, and the extracted data is used by data converter to 
populate SQL database 170. Similarly, XML data 174 provides an industry- 
5 standard method for exchanging data with SQL databases 170. Thus, as described 
for one embodiment, data for use in the system is stored, or converted and stored, 
in SQL database 170 (except for data in site server 160). 

General System Operation 

1 o Referring now to Fig. 2, a general flow for the system is described. An end- 

user will generally access a web site developed using an embodiment of the 
invention through a web browser 106 on a client machine 202. When an end-user 
initiates a request (typically through a button or a field provided on a web page), the 
request is communicated to a server 204 through foundation 110. In particular, the 

1 5 end-user request initiates a "response loop" 112, which is part of the "presentation 
services" for the system. Response loop 1 12 initially processes the request and 
selects an appropriate business module 130 to carry out the request whose 
functionality correlates to the request. An object for the appropriate module 130 
is instantiated and further processes the request and calls data services 118, located 

20 in the foundation, to collect the requested data from data storage 170-174. Data 
services 1 18 retrieve and save data for modules 130 from/to persistent storage. 

Once data is retrieved, it is returned to the appropriate module 130, which 
in turn returns the information to the response loop 1 12. The response loop 112, 
through a page generator, then generates an appropriate responsive web page 

25 displayed to the end-user through the end-user's browser. 

In sum, a system in accordance with the invention operates as a series of 
successive cycles, where each cycle consists of request data being entered by the 
end-user on the client machine through a browser and converted into a specific 
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request for information from the data stores. The flow then reverses as the 
requested information is returned. Each cycle culminates when an appropriate 
response to the request is formatted and sent back to the browser for the end-user 
to view. The end-user reacts to what he/she sees and the process repeats. This 
5 repeated cycle comprises most of the activity in the system. 

Response Loop/Page Generator 

Now referring to Fig. 3, the response loop 1 12 is described in further detail. 

When a new request (initiated by an end-user) is received, a facilitator object 302 

10 is instantiated. The facilitator has one method: execute. All commands (including 

administrative commands) are sent into the system through this method in one 

embodiment. The execute method typically has the following signature: 

Facilitator, execute (string module, string action, string criteria, 
string template, string debug). 

15 

"Module" names the business module for which an object is to be invoked. 

"Action" represents the action to be carried out by the business module object. 

"Criteria" represents any variable parameters required for the action. "Template" 

specifies an XSL style sheet to be returned. The "template" parameter is optional 
20 and only included in some embodiments. It is an empty string by default. And 

"debug" specifies logging and tracing to be activated. 

This execute method creates a context object 304 for the individual request. 

The context object 304 stores and holds information for each request and exists for 

the life of the request. When the context object is instantiated, the parameters from 
25 the Facilitator execute method are copied into the object. During the life of the 

request, the context object stores the state of the request. Other objects in the 

response loop will later consult with and update the context object for this particular 

information as shown by the dashed lines. 
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Once the relevant initial request data is stored in context object 304, the 
facilitator' s execute method initiates a dispatcher object 306 and passes the context 
object to it. The dispatcher object 306 takes the context object and invokes a 
validator object 308 to validate the information contained in the context object 304. 
5 The validator verifies the attributes of the context object against a grammar 
repository in the DIT before further operation. If an error is found by the validator 
308, the dispatcher 306 sends a message to an error handler in the foundation low 
level services 120. But if no errors are found by the validator 300, then dispatcher 
306 invokes a Business Object Factory (BizObjFactory) 310. BizObjFactory 3 10 

10 consults the context object 304 to determine the type of module 130 required. 
BizObjFactory 310 then instantiates a business object 312 corresponding to the 
appropriate module 130. Business object 312 is shown in phantom since it is not 
necessarily part of the foundation (unless it is cart 1 14). Business object 3 12 then 
performs the necessary functionality, and if necessary, uses data services 118 to 

15 obtain data from an appropriate data store. 

The business object 3 12 then converts any data it has retrieved into XML 
format, invokes the page generator 314, and sends the XML data to page generator 
3 14. Page generator 314 consults the context object 304 to obtain an XSL style 
sheet (described below) appropriate to illustrate a response to the end-user. Page 

20 Generator 3 14 combines the retrieved XSL style sheet with the XML data and 
produces an HTML web page, storing the HTML result in the context object. The 
web page is then output to the end-user's browser. 

System Customization 

25 A system in accordance with the invention can be easily customized by a 

company-user. In a first level of customizability, the company-user selects which 
business modules 130 it desires in its system. In the some embodiments, business 
modules will be produced by one or more third-party companies, the supplier of the 
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foundation, or could even be defined or designed by the company-user. In many 
embodiments, a company-user may start out with a selected subset of possible 
modules and then add (or subtract) modules over time. On installation of a module, 
none of the other modules are effected, and the foundation is only minimally 
5 effected with the addition of information to recognize the new module, for instance, 
information used in the response loop to validate requests and to call selected 
modules. 

Each module 130 has a set of templates associated with it, each template 
representing a model of a web page, or a generic web page. The company-user 
10 selects which template it desires to use, a second level of customizability, and then 
forms a web page by customizing the selected template, a third level of 
customizability. 

In particular, in one embodiment templates are XSL style sheets that 
determine the look and feel for a particular web page. As used herein, "look and 

15 feel" refers to the graphic design elements of a web page, including but not limited 
to, layout, color, font, size, titles, text, graphics, and button styles. Templates are 
generically designed to allow use in a variety of business situations. Templates 
include placeholders for titles, headers, and buttons. An example template that 
might be used in one embodiment with "locate" module 146 is shown in Fig. 4. 

20 Other example templates that might be used to replace that shown in Fig. 4 are 
shown in Figs. 6-8. Each of these templates vary slightly from one another, 
particularly in the information they are to search for (e.g., zip code, dealer name, 
city, state, etc.). While the templates shown in Figs. 4 and 6-8 are relatively simple 
in appearance, more complex templates could be easily provided. Hence, part of 

25 the web site customization process includes selecting which templates the company- 
user believes are most suitable for conveying relevant information to its end-users. 

The look and feel of each of these generic templates can be customized and 
thus tailored to be used for a particular company-user, but without the time and 
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effort to create a page from scratch. For instance, font, sizes, layout, and styles can 
be edited. Also selected areas can be stylized, for instance headers and titles can be 
replaced with graphic text and images. Button styles and color schemes can also 
be edited. An example of the template of Fig. 4 as customized is illustrated in 
5 Fig. 5 . Thus, considerable flexibility is provided to the company-user to customize 
its web pages. Still, despite this flexibility, a few elements cannot be validly 
eliminated such as any required input fields and buttons to allow the page to 
function properly. Still, the placement, size, and look of these required elements 
can be altered. 

10 In one embodiment of the invention cascading style sheets (CSS) are 

utilized. CSS provide the advantage of being able to change font type, sizes, and 

style across an entire template family simply by editing a single CSS style sheet 

rather than revising each template individually. 

Thus, the company-user decides which templates best suit the company- 
15 user's needs. The company-user can then change colors, add company-specific 

graphics, icons, and fonts and make adjustments to the layout appearance. 

Customized templates are saved as a new XSL file that will be used by the page 

generator 314 to provide information to an end-user. 

Within each template is embedded one or more commands. By selecting 
20 certain templates or changing templates, the commands used with the system (and 

thus the functions performed by the system) can be altered, thereby allowing easy 

alterability of the system's functionality and flow. 

For instance, the following command may be included in a "locate" template 

(a template for use with locate module 146): 

25 



COMMAM>NAME 


COMMAND FORMAT 


LocateByZip 


OFacilitator.Execute ('"Locate", "LocateByZip", criteria, style), 
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where "Locate" represents the module to carry out the command, "LocateByZip" 
represents a specific command or action, and "criteria" represents variable 
parameters for the command, e.g., a zip code (such as 94941) entered by an end- 
user. The "style" parameter is optional and only used in some embodiments, but in 
5 one embodiment it is a string containing the complete pathway to a particular 
responsive style sheet, allowing the company-user to "override" a default style 
sheet. The result of this particular command is the retrieval of a list of company 
partners proximate to a particular zip code. Thus, when a request for information 
is entered by an end-user e.g., through buttons or fields on a customized template 
10 (the web page), the request is provided to the system in the form of a command 
such as that shown above. 

Other examples of commands that may be used in one embodiment with 
"locate" templates include: 



15 



COMMAND NAME | COMMAND FORMAT 


LOCATE COMMANDS 


LocateByZip 


OFacilitator.Execute ("Locate", "LocateByZip", criteria, style) 


LocateByZipXact 


OFacilitator.Execute ("Locate", "LocateByZipXact", criteria, 
style) 


LocateByCityState 


OFacilitator.Execute ("Locate", "LocateByCityState", criteria, 
style) 


LocateByDealer 


OFacilitator.Execute ("Locate", "LocateByDealer", criteria, style) 


LocateDriveMapForm 


OFacilitator.Execute ("Locate", "LocateDriveMapForm", criteria, 
style) 


GetDriveMap 


OFacilitator.Execute ("Locate", GetDriveMap", criteria, style) 


GetLocalMap 


OFacilitator.Execute ("Locate", "GetLocalMap", criteria, style) 


GetNext 


OFacilitator.Execute ("Locate", "GetNext", criteria, style) 


GetNextPick 


OFacilitator.Execute ("Locate", "GetNextPick", criteria, style) 


ShowPage 


OFacilitator.Execute ("Locate", "ShowPage", criteria, style) 
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Other examples of commands for other modules include: 



COMMAND SfAME | COMMAS FORMAT 


CATALOG COMMANDS 


GetCross 


OFacilitator.Execute ("Catalog", "GetCross", criteria style) 


GetProduct 


OFacilitator.Execute ("Catalog", "GetProduct", criteria style) 


GetProductSKU 


OFacilitator.Execute ("Catalog", "GetProductSKU", criteria style) 


ReadCategoiy 


OFacilitator.Execute ("Catalog", "ReadCategory", criteria style) 


SearchProduct 


OFacilitator.Execute ("Catalog", "SearchProduct", criteria style) 


SearchProductCount 


OFacilitator.Execute ("Catalog", "SearchProductCount", criteria 
style) 


SearchProductLimit 


OFacilitator.Execute ("Catalog", "SearchProductLimit", criteria 
style) 


SearchProductXML 


OFacilitator.Execute ("Catalog", "SearchProductXML", criteria 
style) 


ShowPage 


OFacilitator.Execute ("Catalog", "ShowPage", criteria style) 


CART COMMANDS 


AddProduct 


OFacilitator.Execute ("Cart", "AddProduct", criteria style) 


AddDealer 


OFacilitator.Execute ("Cart", "AddDealer", criteria style) 


GetCompleteCart 


OFacilitator.Execute ("Cart", "GetCompleteCart", criteria style) 


GetStoredCart 


OFacilitator.Execute ("Cart", "GetStoredCart", criteria style) 


GetCartProducts 


OFacilitator.Execute ("Cart", "GetCartProducts", criteria style) 


RemoveProduct 


OFacilitator.Execute ("Cart", "RemoveProduct", criteria style) 


RemoveDealer 


OFacilitator.Execute ("Cart", "RemoveDealer", criteria style) 


ClearCart 


OFacilitator.Execute ("Cart", "ClearCart", criteria style) 


ClearCartProducts 


OFacilitator.Execute ("Cart", "ClearCartProducts", criteria style) 


TRANSACT COMMANDS 


RFQ Action 


OFacilitator.Execute ("Transact", "RFQ", criteria style) 


ShowPage 


OFacilitator.Execute ("Transact", "ShowPage", criteria style) 
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Thus, a relatively small set of commands is used to create a customized system, 
where the commands are easily selected through the selection of templates. 

A system in accordance with the invention can further be customized using 
the rule engine 124 (Fig. 1). The rule engine 124 allows the system to perform in 
5 a way unique to each company-user by allowing a company-user to develop sets of 
performance-defining rule. An example of a rule, expressed in some unspecified 
syntax, is: 



if customer is young 
10 and customer lives somewhere hot 

then an open-top vehicle should be considered 

Rule can be generated automatically, by the system, or manually, by the 
company-user. Rule could be generated automatically, for instance, by examining 

1 5 the structure and contents of the catalog database to generate rule used by the build 
module (which allows end-users to design products) or by the assess module (which 
assesses an end-users needs and provides product recommendations). Manual rule 
generation (e.g., done by an administrator for the company-user) can be done with 
tools similar to those provided by Microsoft in their various e-mail clients, by 

20 allowing rule to be built with point and click techniques. Hence, business rule can 
be added to the system dynamically, without a requirement for changing application 
code. 

A system in accordance with the invention is further customizable in that it 
allows for "back-end integration." In other words a system in accordance with the 
25 invention provides the ability of the system to integrate with other third party 
systems by allowing the present system to send data out to and get data back from 
other third party systems. Typically such data communication will be done using 
XML data. For instance, an object for the transact module 144 may pass order 
information (e.g., a representation of the cart) in the form of an XML document (via 
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a DAO, discussed later) to a third party order fulfillment system that performs 
inventory control, shipping, etc. Similarly, the transact module could receive 
information in XML format from the same order fulfillment system indicating a ship 
date, which information could then be provided to the end-user. By way of further 
5 example, an object for location module 146 could receive XML data from a map 
provider. 

Other Foundation Services 
Cart 114 (Fig. 1) 

10 Cart 1 14 is essentially a module akin to business modules 130, but because 

it is used by many other modules 130, it is located in foundation 110. Cart 1 14 can 
store information sufficient to define a product order and present it to the company- 
user or to company partners for price quoting. Thus, as is understood in the art, 
cart 1 14 is a mechanism for temporary storage that either holds, or provides access 

1 5 to, information identifying the customer, the company partner (if any) from whom 
the customer wishes to perform the transaction, and the products or services 
ordered. 

As with the other business modules, an object for cart 1 14 is invoked by the 
response loop. The cart object consults with the context object and performs the 
20 appropriate specified action. When the action is complete, including gathering data 
through use of data services 118, then the cart object forwards XML data to the 
page generator to format it and return it to the end-user's browser. 

Data Services 118 

25 Data Services 118 is a server-based set of components whose primary 

responsibility is to retrieve and save data for the modules 130 from and to persistent 
storage. The primary components of Data Services 118 are data access objects 
(DAOs). 
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DAOs are the only objects in the system that have "knowledge" about how 
data is stored. DAOs effectively insulate the rest of the system from the specifics 
of data handling. DAOs interact directly with the data stores (e.g., SQL database 
170, the DIT, or with outside data services such as map providers). 
5 A DAO is initiated by an object correlated to a business module 130 

(including cart 114), e.g., locate, catalog, transact. Once initiated, the DAO 
interfaces with the appropriate data store to store/retrieve information. 

In some embodiments, data management objects (DMOs) are used in some 
instances in conjunction with DAOs. DMOs essentially manage DAOs and can be 
10 used to encapsulate or "wrap" a number of related DAOs. For instance, a DMO 
may encapsulate a DAO that retrieves data from the SQL database 120 and a DAO 
that retrieves data from the DIT when both DAOs are for use with the catalog 
module. An object for the catalog module can then simply call the DMO, which 
then directs the call to the appropriate DAO. 

15 

Low Level Services 120 (Fig. 1) 

The foundation 110 also includes a number of low level services, including 
error handling, message handling, and security. Low level services further include 
a "customer object" which stores and retrieves end-user information from the DIT. 

20 Low level services also include session state management. A session is 

defined as the time period that an end-user is continuously on a web site. If the end- 
user explicitly ends the session or is silent for a particular set time period (e.g., 20 
minutes), a session is said to have ended. While an end-user is in a session, a state 
handler temporarily stores any data selected by the end-user (such as products in the 

25 shopping cart) in RAM (random access memory) for better performance. 

A conventional method for managing session state is provided with 
Microsoft's IIS web server for ASP sessions. A session is created when an end- 
user first accesses a web page on a web site. Creation of the session results in a 
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cookie (a text file) being stored on the client computer, which is then available for 
any application to use. As well, the web pages can create and use "session 
variables" to store data for use on any page (session state). The session variables 
stored are specific to the particular sessions. Other end-users or other sessions for 
5 the same end-user will have different session variables. 

But with this Microsoft technology, particular session variables can exist 
only on the server where they were created. Hence, when a web application is 
scaled by distributing it to multiple servers, particularly to accommodate high end- 
user access, this approach to maintaining session state does not work. 

10 Nonetheless, in an embodiment in accordance with the invention, multiple 

web application servers are used and session state can be accesssed from any server. 
In particular, session state in accordance with the invention stores a cookie that 
includes a session ID or user ED on the client computer to identify the session, much 
like that done conventionally. But unlike that done conventionally, in an 

1 5 embodiment of the present invention, session state is implemented as an NT service, 
which automatically starts upon system boot up. As an NT service, the session state 
service can be used remotely (from a different machine), allowing more than one 
application server to access one central session state. Thus, a business module 
object can place its data in a memory store which persists for the term of an end- 

20 user session allowing data to be quickly accessed from multiple servers between 
web pages during a session. 

Administrative Support and Management Services 

Foundation 110 further includes management services 122 (Fig. 1). 
25 Management services 122 is used for administrative activities performed by the 
user. In one embodiment, management services are accessed by the company-user 
using a browser. Management services 122 provides the administrative interfaces 
and services for each of the modules and foundation, including a number of 
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configuration options, which are stored in the DIT. For instance, management 
services allows the company-user to select a search or map provider for use with 
a locate module and a fax provider for use with the transact module. Management 
services further allows for data management, including control of the database, that 
5 is needed to build and maintain catalog and product information. Many other 
administrative functions are available through the management services. 

The DIT works in conjunction with management services storing 
administrative settings as discussed above. The DIT further stores validation data 
(used by the validator 308 (Fig. 3)) as well as the site server membership directory 
10 structure (for tracking end-users). 

Scalability 

A system in accordance with the invention is also easily scalable. In one 
embodiment, as shown in Fig. 9, the system can be installed on one server 904 to 

1 5 support the web application (e.g., presentation services, business services, and data 
services shown in Fig. 2) and session state management while a second server 906 
is used to support data storage (product database and membership directory). But 
in other embodiments, as shown in Fig. 10, many more servers may be used, 
depending on the company-user's needs and considering factors such as load 

20 balancing and security. As shown in Fig. 10, a load balancing router 903 is used, 
and one or more servers are used to separately support the web application 
(904a-d), the product database (906a-b), session state (908), and membership 
directory services (910a-b). Providing the ability to access session state from 
multiple machines (discussed previously) greatly enhances the scalability of the 

25 system. 
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E-Commerce Sales Model 

One embodiment of the invention is particularly useful for modeling a sales 
environment for e-commerce. As shown in Fig. 1 1, the modules 130 of Fig. 1 can 
be used to mimic a non-electronic sales process. 
5 For instance, consider a hypothetical furniture purchase. When a customer 

walks into a furniture showroom, a sales person may interact with the customer, 
discuss the customer's available furnishable space and its planned use of the 
furniture. After those discussions, the sales person may make a product 
recommendation. The assess module 132 operates in a similar fashion, interactively 
1 0 guiding an end-user to determine their product needs through a series of questions, 
choices, and rating scales and then displaying product recommendations that match 
the end-user's buying criteria. The access module 132 will frequently be used with 
rule engine 124. 

Continuing the hypothetical purchase process, the customer may wish to 
1 5 view various pieces of furniture in the showroom, finding out dimensions, materials, 
and other relevant information. Similarly, the catalog module 134 operates to 
illustrate to an end-user product information, potentially including graphic images, 
media files, as well as descriptive text information. 

In some situations, a customer may need a custom-designed piece of 
20 furniture. The build module 136 allows an end-user to interactively configure such 
a piece of furniture specific to their needs, preferences and budget, for instance in 
terms of fabric selection, dimensions, leg style, etc. The build module 136 guides 
the end-user through various options and ensures that the end-user chooses a 
product that conforms to engineering and manufacturing requirements. The build 
25 module 136 will frequently be used with rule engine 124. 

In many instances, a customer will want to compare two or more products 
for characteristics, quality, price, etc. The compare module 138 allows an end-user 
to compare the features of multiple products from different companies or product 
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lines. In other words compare module 138 allows for side-by-side comparison of 
the company-user's products and/or a competitor's products. 

During the sales process, the sales person may mention to the customer that 
certain products are on sale or are associated with special promotions. The 
5 promote module 140 operates in the same way, allowing end-users to view sales, 
rebates, incentives, offers, and promotions on-line. 

A customer seriously interested in making a furniture purchase may be 
offered credit or a financing package by the sales person. In a similar manner, the 
finance module 142 gives an end-user the ability to apply for credit or to calculate 
10 various financing scenarios. For instances, the finance module 142 allows an end- 
user to apply for credit approval, perform "what if calculations (such as varying 
price, down payment, and finance terms), and perform lease versus finance 
comparisons. 

Once a customer is ready to make a purchase, a sales transaction occurs. 

15 In the on-line environment created by an embodiment of the invention, a similar 
transaction takes place. In some embodiments, such a transaction may be carried 
out simply by the end-user's supplying a credit card. In other embodiments, 
however, the transact module 144 forwards the end-user's information and product 
selection to an associated company partner. To do so, transact object consults the 

20 cart object for the selected products, company partner, and end-user information. 
If any information is missing, transact initiates the process for selecting one, e.g., 
by returning a request to initiate the appropriate modules. The transact module 
further obtains the end-user's information from a data store. If no information yet 
exists, a template (customized by the company-user) is provided to the end-user to 

25 fill in the required information. The information is forwarded to the selected 
associated company partner by e-mail, fax, or XML document. In this way a 
company can do business on-line but maintain its current business model without 
disintermediating its company partners. 
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The locate module 146 allows the end-user to select which company partner 
will be contacted by the transact module 144. Such selection can take place by 
identifying a retailer name, zip code, or other information and, in some 
embodiments, interfacing with a geo-mapping service to provide specific location 
5 information. The end-user and selected company partner then finalize the purchase. 

In some embodiments of the invention, end-user loyalty is promoted using 
a loyalty module 148. The loyalty module increases end-user loyalty through 
relationship building activities. Such activities include providing an end-user with 
personalized buying opportunities, appropriately timed maintenance reminders, and 

10 service offerings. The loyalty module 148 will also in some embodiments include 
e-mail subscriptions, a secure environment for end-user interactions (e.g., with 
password protection), on-line access to documentation such as manuals and 
warranties, and chat capabilities. In some embodiments, access to the loyalty 
features will be available for "members only." That is, access to the loyalty features 

15 is controlled by a login process. A membership management system is utilized to 
trace and maintain information about "members" and to allow for the creation of 
new members. In some embodiments, such a membership management system is 
based on Microsoft Site Server 3.0 Membership Authentication Mode HTML 
Forms Authentication Method. In some embodiments the information provided to 

20 members by loyalty module will also be personalized - i.e., geared specifically to the 
member end-user based on stored information about the end-user. 

Other business modules 154 performing other functions can also be 
incorporated. Thus, there are limitless possibilities to the types of modules that 
could be used. For instance, a module 130 could be developed to support travel 

25 agency-type applications, applications for financial or investment institutions, or an 
infinite number of others. 
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Some embodiments of the invention may use less than all of the modules as 
shown in Fig. 1 1 . For instance, a useful embodiment of the invention will use only 
the catalog, transact, and locate modules. 

Some embodiments of the invention further enable a main company-user site 
5 as well as affiliated sites managed by associated company partners. The site builder 
module 1 50 allows the associated company partner to easily build sites with unique 
domain names that are approved by the main company-user. The main company 
site may be supported by different modules than the affiliated sites. For instance, 
the main company site may use the catalog, build, transact, and locate modules 
10 while the affiliated sites use only the transact and build modules. 

Some embodiments of the invention further provide company partners with 
a lead manager module 152. Lead manager module 152 assists company partners 
in tracking and managing sales leads as they are delivered from the main company- 
user web site. 

Thus, a system has been described that provides highly modular, easily 
modifiable e-commerce software. Each system can be customized by a company- 
user in terms of function and look and feel, yet the system does not need to be built 
from scratch. In other words, a user is provided with a prebuilt, yet customizable 

20 system that avoids the need to purchase an expensive custom system or an inflexible 
shrink-wrapped system. 

It should be understood that the particular embodiments described above are 
only illustrative of the principles of the present invention, and various modifications 
could be made by those skilled in the art without departing from the scope and spirit 

25 of the invention. Thus, the scope of the present invention is limited only by the 
claims that follow. 
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CLAIMS 



What is claimed is: 



1 . A system for providing a web site, comprising: 

a plurality of business modules from which a company-user selects a set of 
business modules; 

wherein each business module provides a respective function; 

wherein each business module is associated with a respective plurality of 
templates, wherein a set of templates is selectable by a company-user from each 
respective plurality of templates; 

wherein said templates control the functionality performed by the system and 
the display of information by the system; and 

wherein said templates are customizable to display graphical elements 
selected by the company-user. 

2. The system of claim 1, wherein each template is a generic web page that is 
associated with at least one command that executes as a result of input received 
from an end-user. 

3 . The system of claim 1 , wherein said plurality of business modules includes: 
a catalog module designed to display product information; 

a transact module designed to facilitate purchasing transactions; and 
a locate module designed to identify a sales location. 

4. The system of claim 3, wherein said plurality of business modules further 
includes at least one of: 

an assess module designed to assess a end-user's needs; 



Attorney Docket No. : SOFT-0 1 002US2 SRM/SBS 
sbs/soft/1002us2/1002.001.wpd 



-24- 

a build module designed to enable the end-user to interactively design 
products specific to the end-user's needs; 

a compare module designed to allow the end-user to compare a plurality 
products; 

5 a promote module designed to allow the end-user to view promotional 

information; 

a finance module designed to provide financing information to the end-user; 
a lead manager module designed to allow sales leads management; 
a loyalty module designed to provide relationship building activities with the 
10 end-user; 

a site builder module designed to allow a partner of the company-user to 
build a company-user-approved web-site. 

5 . The system of claim 1 , wherein the plurality of business modules includes: 
15 a loyalty module designed to provide relationship building activities with an 

end-user. 

6. The system of claim 1, wherein the plurality of business modules includes: 
a loyalty module designed to provide relationship building activities with an 

20 end-user including one or more of the following services: 

membership services; 

personalized information services; 

personalized buying opportunity services; 

e-mail subscription services; 
25 on-line access to documentation services; 

chat services. 
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7 . The system of claim 1 , wherein the set of business modules selected includes 
all of the business modules in said plurality of business modules. 



8 . The system of claim 1 , wherein the set of business modules selected includes 
5 less than all of the business modules in said plurality of business modules. 

9. The system of claim 1 , wherein an additional business module selected from 
said plurality of business modules can be added to the system. 

10 10. The system of claim 1, wherein one of the business modules from said 
selected set of business modules can be subtracted from the system. 

11. The system of claim 1, wherein each business module operates 
independently of the other business modules, but a particular business module can 

15 still receive information that was generated by another business module. 

12. A system for providing a web site, comprising: 

a set of business modules selected by a company-user; 

wherein each business module provides a respective function; 
20 wherein each business module is capable of performing a plurality of 

commands related to its function and is customizable to perform a set of those 
commands selected by the company-user; 

wherein each business module is associated with a plurality of generic web 
pages that are customizable to have a look and feel selected by the company-user. 

25 

13 . The system of claim 12, wherein each generic web page is associated with 
at least one of said commands, wherein the selected set of commands is selected by 
selecting a set of generic web pages. 
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14. The system of claim 12, wherein the generic web pages are customizable to 
have a look and feel selected by a company-user by changing any of the following: 
titles, buttons, fonts, and colors. 

5 15. The system of claim 14, wherein the generic web pages are further 
customizable to have a look and feel selected by a company-user by adding graphics 
and media. 

16. The system of claim 12, wherein said set of business modules includes: 
10 a catalog module designed to display product information; 

a transact module designed to facilitate purchasing transactions; and 
a locate module designed to identify a sales location. 

17. The system of claim 16, wherein said set of business modules further 
15 includes at least one of: 

an assess module designed to assess a end-user's needs; 
a build module designed to enable the end-user to interactively design 
products specific to the end-user's needs; 

a compare module designed to allow the end-user to compare a plurality 
20 products; 

a promote module designed to allow the end-user to view promotional 
information; 

a finance module designed to provide financing information to the end-user; 
a lead manager module designed to allow sales leads management; 
25 a loyalty module designed to provide relationship building activities with an 

end-user; and 

a site builder module designed to allow a partner of the company-user to 
build a company-user-approved web-site. 
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18. The system of claim 12, farther including a second set of business modules 
used by a partner of the company-user. 

1 9. The system of claim 1 8, wherein the second set of business modules includes 
5 a site builder module designed to allow the partner to build a company-user- 
approved web site. 

20. The system of claim 12, further including a loyalty module designed to 
provide relationship building activities with an end-user including one or more of 

10 the following services: 

membership services; 

personalized information services; 

personalized buying opportunity services; 

e-mail subscription services; 
15 on-line access to documentation services; 

chat services. 

2 1 . The system of claim 12, wherein the set of business modules is selected from 
a plurality of available business modules and includes all of the business modules in 

20 said plurality of available business modules. 

22 . The system of claim 1 2, wherein the set of business modules is selected from 
a plurality of available business modules and includes less than all of the business 
modules in said plurality of available business modules. 

25 

23 . The system of claim 12, wherein an additional business module can be later 
selected and added to the system. 
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24. The system of claim 12, wherein one of the business modules can be 
subtracted from the system. 

25. The system of claim 12, wherein each business module operates 
5 independently of the other business modules, but a particular business module can 

still receive information that was generated by another business module. 

26. A system for providing a web site, comprising: 
a foundation, wherein: 

10 the foundation is adapted to interact with a web browser; 

the foundation serves as an interface between each of a 
plurality of business modules and the web browser; 

the foundation is adapted to interact with any of the business 
modules such that selected business modules can be added to or 
15 subtracted from the system; and 

upon receiving a request from the web browser, the 
foundation is adapted to invoke the business module appropriate to 
the request to carry out the request. 

20 21. The system of claim 26, wherein the foundation is further adapted to interact 
with a data store and to serve as an interface between each of the plurality of 
business modules and the data store. 

28. The system of claim 26, wherein the request is generated by a web page 
25 associated with a specific business module, and wherein the foundation is adapted 
to invoke the business module appropriate to the request to carry out the request 
by: 
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storing request parameters in a context object, where the parameters include 
an identification of the specific business module; 

consulting the context object for the identification of the specific business 
module; and 

5 invoking the business module that is identified by the identification. 

29. The system of claim 26, wherein selected business modules can be added to 
or subtracted from the system with minimal modification to the foundation. 

10 30. The system of claim 26, where the foundation includes resources commonly 
used by the business modules. 

31. A system for providing a web site, comprising: 

(a) a set of business modules selected by a company-user from a 
15 plurality of business modules, wherein: 

each business module provides a respective function; 

each business module is capable of performing a plurality of 
commands related to its function and is customizable to perform a 
set of those commands selected by the company-user; 
20 each business module is associated with a plurality of generic 

web pages that are customizable to have a look and feel selected by 
the company-user; and 

(b) a foundation, wherein: 

the foundation is adapted to interact with a web browser; 
25 the foundation serves as an interface between each of the 

business modules and the web browser; 

the foundation is adapted to interact with any of the plurality 
of business modules such that additional selected business modules 
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ean be added to the system and selected business modules can be 
subtracted from the system; and 

upon receiving a request from the web browser, the 
foundation is adapted to invoke the business module appropriate to 
5 the request to carry out the request. 

32. The system of claim 3 1 , wherein each generic web page is associated with 
at least one of said commands, wherein the selected set of commands is selected by 
selecting a set of generic web pages. 

10 

33 . The system of claim 3 1, wherein the set of business modules includes all of 
the business modules in said plurality of available business modules. 

34. The system of claim 3 1, wherein the set of business modules includes less 
15 than all of the business modules in said plurality of available business modules. 

3 5 . The system of claim 3 1 , wherein the foundation is further adapted to interact 
with a data store and to serve as an interface between each of the plurality of 
business modules and the data store. 

20 

36. The system of claim 31, wherein the request is generated by a web page 
associated with a specific business module, and wherein the foundation is adapted 
to invoke the business module appropriate to the request to carry out the request 
by: 

25 storing request parameters in a context object, where the parameters include 

an identification of the specific business module; 

consulting the context object for the identification of the specific business 
module; and 
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invoking the business module that is identified by the identification. 



37. The system of claim 31, wherein the business modules can be added to or 
subtracted from the system with minimal modification to the foundation. 

5 

3 8 . The system of claim 3 1 , where the foundation includes resources commonly 
used by the business modules. 

39. A method for use in a system for providing a web site, comprising: 

1 0 receiving an end-user request from a web browser by a system that includes 

a selected set of business modules, where each business module is associated with 
a respective function and where the functions performed by each business module 
are selected by a company-user; 

processing the end-user request by the system, and invoking, by the system, 
15 an appropriate business module to implement the end-user request; 

receiving resulting data from the appropriate business module; and 
generating a web page including graphical elements selected by the 
company-user and including at least some of the resulting data for display by the 
web browser as a response to the end-user request. 

20 

40. The method of claim 39, wherein: 
processing the end-user request includes: 

creating a context object that includes the parameters of the end- 
user request; and 
25 validating the context object; and 

selecting an appropriate business module includes consulting the context 
object to determine the appropriate business module and instantiating a business 
object correlated to the business module. 
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4 1 . The method of claim 3 9, farther including: 

retrieving by the system, at the request of the appropriate business module, 
data from a data store and returning the retrieved data to the business module. 

5 42 . The method of claim 4 1 , wherein retrieving data from a data store includes 
instantiating a data access object. 

43. The method of claim 39, wherein receiving resulting data from the 
appropriate business module includes receiving such data in XML format. 

10 

44. A method for use with a system for providing a web site, comprising: 
selecting and installing a set of business modules selected from a plurality 

of business modules, where each business module is associated with a respective 
function; 

15 selecting for each business module a set of predefined generic web page 

templates, where each template is associated with a respective action; and 

customizing each selected template to achieve a selected look and feel. 

45. The method of claim 44, wherein said set of business modules includes less 
20 than all of the business modules in said plurality of business modules. 

46. The method of claim 45, farther comprising: 

later selecting and installing another business module. 

25 47. A system for providing an internet sales environment, comprising: 

a web site to interface with an end-user, the web site guiding the end-user 
through a sales process by utilizing a selected set of one or more modules 
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previously selected from a plurality of modules, where the plurality of modules 
includes: 

an assess module designed to determine the end-user's needs and 
provide a personalized product recommendation; 
5 a catalog module designed to display and maintain product 

information; 

a build module designed to enable the end-user to interactively 
assemble products and services specific to the end-user's needs; 

a compare module designed to allow the end-user to compare 
10 multiple products; 

a promote module designed to allow the end-user to view 
promotional information; 

a finance module designed to give a end-user the ability to examine 
financing scenarios; 

15 a transact module designed to facilitate a sales transaction. 



48. The system of claim 47, wherein the plurality of modules further includes: 
a locate module designed to identify a sales location; 
a lead manager module designed to allow sales leads management; 
20 a loyalty module designed to provide relationship building activities 

with the end-user; and 

a site builder module designed to allow the partner of the company- 
user to build a company-user-approved web-site. 



25 49. A system for providing an internet sales environment, comprising: 

a web site to interface with an end-user, the web site guiding the end-user 
through a sales process by utilizing a selected set of modules that includes: 
a catalog module; 
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a locate module. 
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50. The system of claim 49, further including: 
a finance module. 

5 1 . The system of claim 49, further including: 
a compare module. 

52. The system of claim 49, further including: 
a loyalty module. 

53 . The system of claim 49, further including: 
an assess module; 

a build module; and 
a promote module. 

54. A system for providing an internet sales environment, comprising: 

a web site to interface with an end-user, the web site guiding the end-user 
through a sales process by utilizing a selected set of modules that includes: 
a catalog module; 
a transact module; and 
a loyalty module. 

55. A system for providing an internet sales environment, comprising: 

a web site to interface with an end-user, the web site guiding the end-user 
through a sales process by utilizing a selected set of modules that includes: 
a build module; 
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a catalog module; 

a transact module; and 

a locate module. 



5 56. The system of claim 55, further including: 
a finance module. 



57. The system of claim 55, further including: 
a compare module. 

10 

58. The system of claim 55, further including: 
a loyalty module. 



59. A system for providing an internet sales environment, comprising: 

a web site to interface with an end-user, the web site guiding the end-user 
through a sales process by utilizing a selected set of modules that includes: 

a assess module; 

a catalog module; 

a transact module; and 

a locate module. 



60. The system of claim 59, further including: 
a finance module. 



25 61 . The system of claim 59, further including: 
a compare module. 



62. A system for providing an internet sales environment, comprising: 
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a web site to interface with an end-user, the web site guiding the end-user 
through a sales process by utilizing a selected set of modules that includes: 
an assess module; 
a build module; 
5 a catalog module; 

a transact module; and 
a locate module. 

63. A method for conducting e-commerce, comprising: 
10 assessing an end-user's needs; 

displaying to the end-user product information; 

allowing the end-user to assemble customized products; 

allowing the end-user to compare a plurality of products; 

displaying to the end-user promotion information; 
15 displaying to the end-user financing information; 

locating a sales location based on information provided by the end-user; and 

forwarding information to the sales location identifying the end-user and any 
products selected by the end-user in order to complete a sales transaction. 

20 64. The method of claim 63, further comprising: 
providing loyalty building services. 

65. The method of claim 63, further comprising: 
managing sales leads. 

25 

66. A computer readable medium have a set of instructions stored therein which 
when executed by a computer causes the computer to provide an on-line sales 
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environment by performing the following steps in response to respective on-line 
end-user requests: 

assessing an end-user's needs; 

displaying to the end-user product and service information; 
5 allowing the end-user to assemble customized products; 

allowing the end-user to compare a plurality of products; 
displaying to the end-user promotion information; 
displaying to the end-user financing information; 

locating a sales location based on information provided by the end-user; and 
1 0 forwarding information to the sales location identifying the end-user and any 

products selected by the end-user in order to complete a sales transaction. 

67. The computer readable medium of claim 66, further including instructions 
to perform the following step: 

15 providing loyalty building services. 

68. The computer readable medium of claim 66, further including instructions 
to perform the following step: 

managing sales leads. 

20 

69. A set of signals sent by a company-user computer, which when received by 
an end-user computer causes the end-user computer to display pages that represent 
an on-line sales environment, the pages including: 

pages for assessing an end-user's needs; 
25 pages for displaying to the end-user product and service information; 

pages for allowing the end-user to assemble customized products; 
pages for allowing the end-user to compare a plurality of products; 
pages for displaying to the end-user promotion information; 
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pages for displaying to the end-user financing information; 
pages for displaying a sales location based on information provided by the 
end-user; and 

pages used for completing a sales transaction. 

5 

70. A method for use by a system that includes a display, comprising: 
displaying a page for use in assessing an end-user's needs; 
displaying a page with product and service information; 
displaying a page for use in assembling customized products; 

10 displaying a page for use in to comparing a plurality of products; 

displaying a page with promotion information; 
displaying a page with financing information; 

displaying a page with a sales location based on information provided by the 
end-user; and 

15 displaying a page for use in completing a sales transaction. 

71. A system for providing an online sales environment, comprising: 

a company user web site that interfaces with an end-user, the web site 
guiding the end-user through a sales process; 
20 a partner web site that interfaces with the end-user; 

wherein the partner web site is constructed utilizing a site builder module 
adapted to allow the partner to build a company-user-approved web site; 

wherein the company-user web site gathers sales lead information from an 
end-user and passes said sales lead information to the partner to complete a sales 
25 transaction with the end-user. 

72. A method, comprising: 

storing a session ID on a client computer; 
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storing a session state corresponding to the session ID on a session state 
server, wherein the session state can be accessed by more than one application 
server. 

5 73 . The method of claim 72, wherein storing a session state is performed by an 
NT service. 
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ABSTRACT 

A system in accordance with the invention creates a predesigned software 
product generally for e-commerce applications that is modifiable by a company-user 
5 in terms of not only look and feel, but also functionality and flow. Such a system 
includes a set of predesigned business modules where each business module 
performs a unique function. Each business module is accompanied by a respective 
set of templates, each of which models a web page. Within each template is 
embedded one or more commands. To customize its system, the company-user 

10 (1) selects which business modules it desires, (2) selects which templates it desires 
to use with each business module, and (3) customizes each template in terms of 
look and feel. By selecting the modules, the company-user determines the system' s 
overall functionality, and by selecting the templates, the company-user determines 
the look and feel and flow of the system. Once customized, the company-user 

15 populates a database for use of the system with company-specific data. 
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(if one name is listed below), first and joint inventor (if plural names are listed below) of the subject matter 
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MODULAR E-COMMERCE WEB SITE DEVELOPMEENT SYSTEM 

the specification of which (check applicable ones): 

X is filed herewith; 

was filed with the above-identified "Filed" date and "SC/Seria! No." 
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Title 37, Code of Federal Regulations, §1.56. 

I hereby declare that all statements made herein of my own knowledge are true and that all 
statements made on information and belief are believed to be true, and further that these statements 
were made with the knowledge that willful false statements and the like so made are punishable by fine 
or im prisonment, or both, under §1 001 of Title 1 8 of the United States Code and that such willful false 
statements may jeopardize the validity of the application or any patent issuing thereon. 
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(1) Date: ^6 




(2) Full name of second 

joint inventor: John Binns 
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(2) Date: 



I************************** 



Attorney Docket No,: SOFT-01002US2 SRM/SBS 
sbs/sof</1002/1 002.002.wpd1 002.002.wpd 



Page 2 



102-001:052396 
08/30/0-11:02 



oni dnodD avurjs bhi 



9E9IS£E9Tt? *W%\ 000S/0E/88 



(3) Full name of third 

joint inventor: Barrv CHne 
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(3) Residence: 
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(3) Citizenship: 
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(3) Date: 
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joint inventor Paula Georae Tompkins _ 



(7) Residence: 3fi Sunshine. S ausalito. California 94965 _ 



{7> Post Office Address: same 
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Titlg 37. Code of Federal Regu lations. 51 .56 

SECTION 1.56. DUTY TO DISCLOSE INFORMATION 
MATERIAL TO PATENTABILITY 



(a) A patent by its very nature is affected with a public 
interest. The public interest is best served, and the most 
effective patent examination occurs when, at the time an 
application is being examined, the Office is aware of and 
evaluates the teachings of all information material to 
patentability. Each individual associated with the filing and 
prosecution of a patent application has a duty of candor and 
good faith in dealing with the Office, which includes a duty 
to disclose to the Office all information known to that 
individual to be material to patentability as defined in this 
section. The duty to disclose information exists with respect 
to each, pending claim mrtil the claim is cancelled or 
withdrawn from consideration, or the application becomes 
abandoned. Information material to the patentability of a 
claim that is cancelled or withdrawn from consideration need 
not be submitted if the information is not material to the 
patentability of any claim remaining under consideration in 
the application. There isno dutyto submit infbrrnatioii which. 
is not material to the patentability of any existing claim. The 
duty to disclose all information known to be material to 
patentability is deemed to be satisfied if all information 
known to be material to patentability of any claim issued m 
a patent was cited by Aft Office or submitted to the Office in 
themanncr prescribed by §§1.97(b)-<d) and L98 * However, 
no patent will be granted on an application in connection with 
which fraud on the Office was practiced or attempted or the 
duty of disclosure was violated through bad faith or 
intentional misconduct. The Office encourages applicants to 
carefully examine: 

(1) prior art cited in search reports of a foreign patent 
office in a counterpart application, and 

(2) the closest information over which individuals 
associated with the filing or prosecution of a patent 
application believe any pending claim patcntably 
defines, to make Sure that any material information 
contained therein is disclosed to the Office. 

(b) Undcrthissection, mformationismaterial to patentability 
when it is not cumulative to infbrmation already of record or 
being made of record in the application, and 



(1) It establishes, ■ itself or in combination with other 
information, a primi facie case of unpatentability of a 
claim; or 

(2) It refutes, or is inconsistent with, a position the 
applicant takes in: 

(i) Opposing a a argument of unpatentability relied 
onbythe Office* 

(ii) Asserting m argument of patentability. 

A prima facie case of uh ratentability is established when the 
mfoirnatioiicompclsaccnclusionthataclaimis unpatentable 
under the preponderate Of evidence, burden-of-ptoof 
standard, .giving each term in the claim its broadest 
reasonable constrecticatwiisist^ 
before any consideration is given to evidence which may be 
submitted in an attempt » establish a contrary conclusion Of 
patentability, 

<c) Individuals associaC ;d with mc filing or prosecution of a 
patent application withh the meaning of this section are: 

(1) Each inventor named hi the application; 

(2) Each attorney or agent who prepares or prosecutes 
the application; an 1 

(3) Every otherpeson who is substantively involved in 
the preparation or prosecution of the application and 
who is associated \riHi the inventor, wiw the assignee or 
with anyone to whom there is an obligation to assign the 
application. 

(d) Individualsotherthmdie attorney, agent or inventor may 
comply with this sectim by disclosing information to the 
attorney, agent, or inventor* 



* §§1.97(bMd) and *- ;>s K]atc to me ri 
which rnforroation is to be submitted to 



** **************** ****** 



t******** 



******* ******** 



********** 
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